/* Animations */
@keyframes debounce {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%,90% { transform: translateX(-2px); }
  20%, 40%, 60%, 80% { transform: translateX(2px); }
}
@keyframes ani-breathing { from { transform: scale(.97);} to { transform: scale(1);} }
@keyframes ani-cursor { from { opacity: 0;} to { opacity: 1;} }
@keyframes ani-routate-Z { from { transform: rotateZ(0);} to { transform: rotateZ(360deg);} }
@keyframes ani-float { from { transform: translateY(-60rpx);} to { transform: translateY(0);} }
@keyframes ani-move-to-right  { 0%, 80% { left: -100%; } 100% { left: 100%; } }

.ani-breathing { animation: ani-breathing .6s ease-out alternate infinite; }
.ani-cursor { animation: ani-cursor 0.5s linear alternate infinite; }
.ani-float { animation: ani-float 1s linear infinite alternate; }
.ani-rotate-Z { animation: ani-routate-Z 4s linear infinite; }
.ani-move-to-right { animation: ani-move-to-right 5s ease-in-out infinite; }

/* Fonts */
@font-face {
	font-family: 'DIN-Bold';
	src: url('/fonts/DIN-Bold.otf');
}
@font-face {
	font-family: 'DIN-Regular';
	src: url('/fonts/DIN-Regular.otf');
}

.ff-DIN-Bold { font-family: 'DIN-Bold'; }
.ff-DIN-Black { font-family: 'DIN-Black';}

/* Common Styles */
* { touch-action: pan-y; margin: 0; padding: 0; box-sizing: border-box; }

a { text-decoration: none !important; }
img { max-width: 100% !important; width: 100%; vertical-align: middle; }
input { outline: none; border: none; }

.tab-page { padding-bottom: calc(50PX + env(safe-area-inset-bottom) ); }
.page { padding-bottom: env(safe-area-inset-bottom); }
.page, .tab-page { width: 100%; min-height: 100vh;  background-color: #F9F9F9; font-family: PingFangSC-Regular, PingFang SC; -webkit-overflow-scrolling: touch; display: flex;  flex-direction: column; }

.safe-area-bottom { padding-bottom: constant(safe-area-inset-bottom); padding-bottom: env(safe-area-inset-bottom); }
.coming-soon { font-size: 32px; text-align: center; padding-top: 30px; color: #88888880; letter-spacing: 2px; }


/* Background & Colors */
.bg-all { background-size: 100% 100% !important;}
.bg-cover { background-size: cover !important;}
.bg-contain { background-size: contain !important; }


.text-white { color: #FFFFFF;}
.text-222222 { color: #222222; }
.text-333333 { color: #333333; }
.text-444444 { color: #444444; }
.text-555555 { color: #555555; }
.text-666666 { color: #666666; }
.text-777777 { color: #777777; }
.text-888888 { color: #888888; }
.text-999999 { color: #999999; }
.text-FFFFFF { color: #FFFFFF; }

/* 红色系 */
.text-red-50 { color: #fef2f2; }
.text-red-100 { color: #fee2e2; }
.text-red-200 { color: #fecaca; }
.text-red-300 { color: #fca5a5; }
.text-red-400 { color: #f87171; }
.text-red-500 { color: #ef4444; }
.text-red-600 { color: #dc2626; }
.text-red-700 { color: #b91c1c; }
.text-red-800 { color: #991b1b; }
.text-red-900 { color: #7f1d1d; }
.text-red-950 { color: #450a0a; }

/* 橙色系 */
.text-orange-50 { color: #fff7ed; }
.text-orange-100 { color: #ffedd5; }
.text-orange-200 { color: #fed7aa; }
.text-orange-300 { color: #fdba74; }
.text-orange-400 { color: #fb923c; }
.text-orange-500 { color: #f97316; }
.text-orange-600 { color: #ea580c; }
.text-orange-700 { color: #c2410c; }
.text-orange-800 { color: #9a3412; }
.text-orange-900 { color: #7c2d12; }
.text-orange-950 { color: #431407; }

/* 黄色系 */
.text-yellow-50 { color: #fefce8; }
.text-yellow-100 { color: #fef9c3; }
.text-yellow-200 { color: #fef08a; }
.text-yellow-300 { color: #fde047; }
.text-yellow-400 { color: #facc15; }
.text-yellow-500 { color: #eab308; }
.text-yellow-600 { color: #ca8a04; }
.text-yellow-700 { color: #a16207; }
.text-yellow-800 { color: #854d0e; }
.text-yellow-900 { color: #713f12; }
.text-yellow-950 { color: #422006; }

/* 绿色系 */
.text-green-50 { color: #f0fdf4; }
.text-green-100 { color: #dcfce7; }
.text-green-200 { color: #bbf7d0; }
.text-green-300 { color: #86efac; }
.text-green-400 { color: #4ade80; }
.text-green-500 { color: #22c55e; }
.text-green-600 { color: #16a34a; }
.text-green-700 { color: #15803d; }
.text-green-800 { color: #166534; }
.text-green-900 { color: #14532d; }
.text-green-950 { color: #052e16; }

/* 蓝色系 */
.text-blue-50 { color: #eff6ff; }
.text-blue-100 { color: #dbeafe; }
.text-blue-200 { color: #bfdbfe; }
.text-blue-300 { color: #93c5fd; }
.text-blue-400 { color: #60a5fa; }
.text-blue-500 { color: #3b82f6; }
.text-blue-600 { color: #2563eb; }
.text-blue-700 { color: #1d4ed8; }
.text-blue-800 { color: #1e40af; }
.text-blue-900 { color: #1e3a8a; }
.text-blue-950 { color: #172554; }

/* 紫色系 */
.text-purple-50 { color: #faf5ff; }
.text-purple-100 { color: #f3e8ff; }
.text-purple-200 { color: #e9d5ff; }
.text-purple-300 { color: #d8b4fe; }
.text-purple-400 { color: #c084fc; }
.text-purple-500 { color: #a855f7; }
.text-purple-600 { color: #9333ea; }
.text-purple-700 { color: #7e22ce; }
.text-purple-800 { color: #6b21a8; }
.text-purple-900 { color: #581c87; }
.text-purple-950 { color: #3b0764; }

/* 粉色系 */
.text-pink-50 { color: #fdf2f8; }
.text-pink-100 { color: #fce7f3; }
.text-pink-200 { color: #fbcfe8; }
.text-pink-300 { color: #f9a8d4; }
.text-pink-400 { color: #f472b6; }
.text-pink-500 { color: #ec4899; }
.text-pink-600 { color: #db2777; }
.text-pink-700 { color: #be185d; }
.text-pink-800 { color: #9d174d; }
.text-pink-900 { color: #831843; }
.text-pink-950 { color: #500724; }

/* 灰色系 */
.text-gray-50 { color: #f9fafb; }
.text-gray-100 { color: #f3f4f6; }
.text-gray-200 { color: #e5e7eb; }
.text-gray-300 { color: #d1d5db; }
.text-gray-400 { color: #9ca3af; }
.text-gray-500 { color: #6b7280; }
.text-gray-600 { color: #4b5563; }
.text-gray-700 { color: #374151; }
.text-gray-800 { color: #1f2937; }
.text-gray-900 { color: #111827; }
.text-gray-950 { color: #030712; }

.bg-F9F9F9 { background-color: #F9F9F9; }
.bg-EEEEEE { background-color: #EEEEEE; }
.bg-DEDEDE { background-color: #DEDEDE; }
.bg-FFFFFF { background-color: #FFFFFF; }


/* 红色系 */
.bg-red-50 { color: #fef2f2; }
.bg-red-100 { color: #fee2e2; }
.bg-red-200 { color: #fecaca; }
.bg-red-300 { color: #fca5a5; }
.bg-red-400 { color: #f87171; }
.bg-red-500 { color: #ef4444; }
.bg-red-600 { color: #dc2626; }
.bg-red-700 { color: #b91c1c; }
.bg-red-800 { color: #991b1b; }
.bg-red-900 { color: #7f1d1d; }
.bg-red-950 { color: #450a0a; }

/* 橙色系 */
.bg-orange-50 { color: #fff7ed; }
.bg-orange-100 { color: #ffedd5; }
.bg-orange-200 { color: #fed7aa; }
.bg-orange-300 { color: #fdba74; }
.bg-orange-400 { color: #fb923c; }
.bg-orange-500 { color: #f97316; }
.bg-orange-600 { color: #ea580c; }
.bg-orange-700 { color: #c2410c; }
.bg-orange-800 { color: #9a3412; }
.bg-orange-900 { color: #7c2d12; }
.bg-orange-950 { color: #431407; }

/* 黄色系 */
.bg-yellow-50 { color: #fefce8; }
.bg-yellow-100 { color: #fef9c3; }
.bg-yellow-200 { color: #fef08a; }
.bg-yellow-300 { color: #fde047; }
.bg-yellow-400 { color: #facc15; }
.bg-yellow-500 { color: #eab308; }
.bg-yellow-600 { color: #ca8a04; }
.bg-yellow-700 { color: #a16207; }
.bg-yellow-800 { color: #854d0e; }
.bg-yellow-900 { color: #713f12; }
.bg-yellow-950 { color: #422006; }

/* 绿色系 */
.bg-green-50 { color: #f0fdf4; }
.bg-green-100 { color: #dcfce7; }
.bg-green-200 { color: #bbf7d0; }
.bg-green-300 { color: #86efac; }
.bg-green-400 { color: #4ade80; }
.bg-green-500 { color: #22c55e; }
.bg-green-600 { color: #16a34a; }
.bg-green-700 { color: #15803d; }
.bg-green-800 { color: #166534; }
.bg-green-900 { color: #14532d; }
.bg-green-950 { color: #052e16; }

/* 蓝色系 */
.bg-blue-50 { color: #eff6ff; }
.bg-blue-100 { color: #dbeafe; }
.bg-blue-200 { color: #bfdbfe; }
.bg-blue-300 { color: #93c5fd; }
.bg-blue-400 { color: #60a5fa; }
.bg-blue-500 { color: #3b82f6; }
.bg-blue-600 { color: #2563eb; }
.bg-blue-700 { color: #1d4ed8; }
.bg-blue-800 { color: #1e40af; }
.bg-blue-900 { color: #1e3a8a; }
.bg-blue-950 { color: #172554; }

/* 紫色系 */
.bg-purple-50 { color: #faf5ff; }
.bg-purple-100 { color: #f3e8ff; }
.bg-purple-200 { color: #e9d5ff; }
.bg-purple-300 { color: #d8b4fe; }
.bg-purple-400 { color: #c084fc; }
.bg-purple-500 { color: #a855f7; }
.bg-purple-600 { color: #9333ea; }
.bg-purple-700 { color: #7e22ce; }
.bg-purple-800 { color: #6b21a8; }
.bg-purple-900 { color: #581c87; }
.bg-purple-950 { color: #3b0764; }

/* 粉色系 */
.bg-pink-50 { color: #fdf2f8; }
.bg-pink-100 { color: #fce7f3; }
.bg-pink-200 { color: #fbcfe8; }
.bg-pink-300 { color: #f9a8d4; }
.bg-pink-400 { color: #f472b6; }
.bg-pink-500 { color: #ec4899; }
.bg-pink-600 { color: #db2777; }
.bg-pink-700 { color: #be185d; }
.bg-pink-800 { color: #9d174d; }
.bg-pink-900 { color: #831843; }
.bg-pink-950 { color: #500724; }

/* 灰色系 */
.bg-gray-50 { color: #f9fafb; }
.bg-gray-100 { color: #f3f4f6; }
.bg-gray-200 { color: #e5e7eb; }
.bg-gray-300 { color: #d1d5db; }
.bg-gray-400 { color: #9ca3af; }
.bg-gray-500 { color: #6b7280; }
.bg-gray-600 { color: #4b5563; }
.bg-gray-700 { color: #374151; }
.bg-gray-800 { color: #1f2937; }
.bg-gray-900 { color: #111827; }
.bg-gray-950 { color: #030712; }



/* Size */
.w-screen { width: 100vw; }
.w-full { width: 100%; }
.w-0 { width: 0; }

.h-screen { height: 100vh; }
.h-full { height: 100%; }
.h-0 { height: 0; }

.min-w-0 { min-width: 0; }
.min-w-full { min-width: 100%; }

.min-h-0 { min-height: 0; }
.min-h-full { min-height: 100%; }

/* Layout */
.aspect-auto { aspect-ratio: auto; }
.aspect-square { aspect-ratio: 1 / 1; }
.aspect-video { aspect-ratio: 16 / 9; }

.box-border { box-sizing: border-box; }
.box-content { box-sizing: content-box; }

.flex { display: flex; }
.block { display: block; }
.inline { display: inline; }
.inline-block { display: inline-block; }

.object-contain { object-fit: contain; }
.object-cover { object-fit: cover; }
.object-fill { object-fit: fill; }
.object-none { object-fit: none; }
.object-scale-down { object-fit: scale-down; }

.object-top-left { object-position: top left; }
.object-top { object-position: top; }
.object-top-right { object-position: top right; }
.object-left { object-position: left; }
.object-center { object-position: center; }
.object-right { object-position: right; }
.object-bottom-left { object-position: bottom left; }
.object-bottom { object-position: bottom; }
.object-bottom-right { object-position: bottom right; }


.overflow-auto { overflow: auto; }
.overflow-hidden { overflow: hidden; }
.overflow-clip { overflow: clip; }
.overflow-visible { overflow: visible; }
.overflow-scroll { overflow: scroll; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-auto { overflow-y: auto; }
.overflow-x-hidden { overflow-x: hidden; }
.overflow-y-hidden { overflow-y: hidden; }
.overflow-x-clip { overflow-x: clip; }
.overflow-y-clip { overflow-y: clip; }
.overflow-x-visible { overflow-x: visible; }
.overflow-y-visible { overflow-y: visible; }
.overflow-x-scroll { overflow-x: scroll; -webkit-overflow-scrolling: touch;}
.overflow-y-scroll { overflow-y: scroll; -webkit-overflow-scrolling: touch;}

.static { position: static; }
.fixed { position: fixed; }
.absolute { position: absolute; }
.relative { position: relative; }
.sticky { position: sticky; }

.fixed-top { position: fixed; top: 0; left: 50%; transform: translateX(-50%); }
.fixed-bottom { position: fixed; bottom: 0; left: 50%; transform: translateX(-50%); }

.absolute-top { position: absolute; top: 0; left: 50%; transform: translateX(-50%); }
.absolute-right { position: absolute; top: 50%; right: 0; transform: translateY(-50%);}
.absolute-bottom { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
.absolute-left { position: absolute; top: 50%; left: 0; transform: translateY(-50%); } 

.absolute-center { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}
.absolute-top-left { position: absolute; top: 0; left: 0; }
.absolute-top-right { position: absolute; top: 0; right: 0; }

.top-0 { top: 0; }
.top-1 { top: 1px; }
.top-2 { top: 2px; }
.top-3 { top: 3px; }
.top-4 { top: 4px; }
.top-5 { top: 5px; }
.top-6 { top: 6px; }
.top-7 { top: 7px; }
.top-8 { top: 8px; }
.top-9 { top: 9px; }
.top-10 { top: 10px; }
.top-11 { top: 11px; }
.top-12 { top: 12px; }
.top-13 { top: 13px; }
.top-14 { top: 14px; }
.top-15 { top: 15px; }
.top-16 { top: 16px; }
.top-17 { top: 17px; }
.top-18 { top: 18px; }
.top-19 { top: 19px; }
.top-20 { top: 20px; }

.right-0 { right: 0; }
.right-1 { right: 1px; }
.right-2 { right: 2px; }
.right-3 { right: 3px; }
.right-4 { right: 4px; }
.right-5 { right: 5px; }
.right-6 { right: 6px; }
.right-7 { right: 7px; }
.right-8 { right: 8px; }
.right-9 { right: 9px; }
.right-10 { right: 10px; }
.right-11 { right: 11px; }
.right-12 { right: 12px; }
.right-13 { right: 13px; }
.right-14 { right: 14px; }
.right-15 { right: 15px; }
.right-16 { right: 16px; }
.right-17 { right: 17px; }
.right-18 { right: 18px; }
.right-19 { right: 19px; }
.right-20 { right: 20px; }


.bottom-0 { bottom: 0; }
.bottom-1 { bottom: 1px; }
.bottom-2 { bottom: 2px; }
.bottom-3 { bottom: 3px; }
.bottom-4 { bottom: 4px; }
.bottom-5 { bottom: 5px; }
.bottom-6 { bottom: 6px; }
.bottom-7 { bottom: 7px; }
.bottom-8 { bottom: 8px; }
.bottom-9 { bottom: 9px; }
.bottom-10 { bottom: 10px; }
.bottom-11 { bottom: 11px; }
.bottom-12 { bottom: 12px; }
.bottom-13 { bottom: 13px; }
.bottom-14 { bottom: 14px; }
.bottom-15 { bottom: 15px; }
.bottom-16 { bottom: 16px; }
.bottom-17 { bottom: 17px; }
.bottom-18 { bottom: 18px; }
.bottom-19 { bottom: 19px; }
.bottom-20 { bottom: 20px; }

.left-0 { left: 0; }
.left-1 { left: 1px; }
.left-2 { left: 2px; }
.left-3 { left: 3px; }
.left-4 { left: 4px; }
.left-5 { left: 5px; }
.left-6 { left: 6px; }
.left-7 { left: 7px; }
.left-8 { left: 8px; }
.left-9 { left: 9px; }
.left-10 { left: 10px; }
.left-11 { left: 11px; }
.left-12 { left: 12px; }
.left-13 { left: 13px; }
.left-14 { left: 14px; }
.left-15 { left: 15px; }
.left-16 { left: 16px; }
.left-17 { left: 17px; }
.left-18 { left: 18px; }
.left-19 { left: 19px; }
.left-20 { left: 20px; }

.visible { visibility: visible; }
.invisible { visibility: hidden; }
.collapse { visibility: collapse; }


.z-0   { z-index: 0;   }
.z-10  { z-index: 10;  }
.z-20  { z-index: 20;  }
.z-30  { z-index: 30;  }
.z-40  { z-index: 40;  }
.z-50  { z-index: 50;  }
.z-60  { z-index: 60;  }
.z-70  { z-index: 70;  }
.z-80  { z-index: 80;  }
.z-90  { z-index: 90;  }
.z-100 { z-index: 100; }
.z-auto { z-index: auto; }


/* Flexbox & Grid */
.flex-row { flex-direction: row; }
.flex-row-reverse { flex-direction: row-reverse; }
.flex-col { flex-direction: column; }
.flex-col-reverse { flex-direction: column-reverse; }

.flex-nowrap { flex-wrap: nowrap; }
.flex-wrap { flex-wrap: wrap; }
.flex-wrap-reverse { flex-wrap: wrap-reverse; }


.flex-auto { flex: 1 1 auto; }
.flex-initial { flex: 0 1 auto; }
.flex-none { flex: none; }

.shrink   { flex-shrink: 1;}
.shrink-0 { flex-shrink: 0;}

.gap-2  { gap: 2px;  }
.gap-4  { gap: 4px;  }
.gap-6  { gap: 6px;  }
.gap-8  { gap: 8px;  }
.gap-10 { gap: 10px; }
.gap-12 { gap: 12px; }
.gap-14 { gap: 14px; }
.gap-16 { gap: 16px; }
.gap-18 { gap: 18px; }
.gap-20 { gap: 20px; }
.gap-22 { gap: 22px; }
.gap-24 { gap: 24px; }
.gap-26 { gap: 26px; }
.gap-28 { gap: 28px; }
.gap-30 { gap: 30px; }
.gap-32 { gap: 32px; }


.justify-start { justify-content: flex-start; }
.justify-end { justify-content: flex-end; }
.justify-end-safe { justify-content: safe flex-end; }
.justify-center { justify-content: center; }
.justify-center-safe { justify-content: safe center; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }
.justify-evenly { justify-content: space-evenly; }
.justify-stretch { justify-content: stretch; }
.justify-baseline { justify-content: baseline; }
.justify-normal { justify-content: normal; }

.justify-items-start { justify-items: start; }
.justify-items-end { justify-items: end; }
.justify-items-end-safe { justify-items: safe end; }
.justify-items-center { justify-items: center; }
.justify-items-center-safe { justify-items: safe center; }
.justify-items-stretch { justify-items: stretch; }
.justify-items-normal { justify-items: normal; }

.justify-self-auto { justify-self: auto; }
.justify-self-start { justify-self: start; }
.justify-self-center { justify-self: center; }
.justify-self-center-safe { justify-self: safe center; }
.justify-self-end { justify-self: end; }
.justify-self-end-safe { justify-self: safe end; }
.justify-self-stretch { justify-self: stretch; }

.content-normal { align-content: normal; }
.content-center { align-content: center; }
.content-start { align-content: flex-start; }
.content-end { align-content: flex-end; }
.content-between { align-content: space-between; }
.content-around { align-content: space-around; }
.content-evenly { align-content: space-evenly; }
.content-baseline { align-content: baseline; }
.content-stretch { align-content: stretch; }

.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.items-end-safe { align-items: safe flex-end; }
.items-center { align-items: center; }
.items-center-safe { align-items: safe center; }
.items-baseline { align-items: baseline; }
.items-baseline-last { align-items: last baseline; }
.items-stretch { align-items: stretch; }

.self-auto { align-self: auto; }
.self-start { align-self: flex-start; }
.self-end { align-self: flex-end; }
.self-end-safe { align-self: safe flex-end; }
.self-center { align-self: center; }
.self-center-safe { align-self: safe center; }
.self-stretch { align-self: stretch; }
.self-baseline { align-self: baseline; }
.self-baseline-last { align-self: last baseline; }

.place-content-center { place-content: center; }
.place-content-center-safe { place-content: safe center; }
.place-content-start { place-content: start; }
.place-content-end { place-content: end; }
.place-content-end-safe { place-content: safe end; }
.place-content-between { place-content: space-between; }
.place-content-around { place-content: space-around; }
.place-content-evenly { place-content: space-evenly; }
.place-content-baseline { place-content: baseline; }
.place-content-stretch { place-content: stretch; }


.place-items-start { place-items: start; }
.place-items-end { place-items: end; }
.place-items-end-safe { place-items: safe end; }
.place-items-center { place-items: center; }
.place-items-center-safe { place-items: safe center; }
.place-items-baseline { place-items: baseline; }
.place-items-stretch { place-items: stretch; }

.place-self-auto { place-self: auto; }
.place-self-start { place-self: start; }
.place-self-end { place-self: end; }
.place-self-end-safe { place-self: safe end; }
.place-self-center { place-self: center; }
.place-self-center-safe { place-self: safe center; }
.place-self-stretch { place-self: stretch; }



/* Spacing */
.p-0 { padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; }
.p-1 { padding-top: 1px; padding-right: 1px; padding-bottom: 1px; padding-left: 1px; }
.p-2 { padding-top: 2px; padding-right: 2px; padding-bottom: 2px; padding-left: 2px; }
.p-3 { padding-top: 3px; padding-right: 3px; padding-bottom: 3px; padding-left: 3px; }
.p-4 { padding-top: 4px; padding-right: 4px; padding-bottom: 4px; padding-left: 4px; }
.p-5 { padding-top: 5px; padding-right: 5px; padding-bottom: 5px; padding-left: 5px; }
.p-6 { padding-top: 6px; padding-right: 6px; padding-bottom: 6px; padding-left: 6px; }
.p-7 { padding-top: 7px; padding-right: 7px; padding-bottom: 7px; padding-left: 7px; }
.p-8 { padding-top: 8px; padding-right: 8px; padding-bottom: 8px; padding-left: 8px; }
.p-9 { padding-top: 9px; padding-right: 9px; padding-bottom: 9px; padding-left: 9px; }
.p-10 { padding-top: 10px; padding-right: 10px; padding-bottom: 10px; padding-left: 10px; }
.p-11 { padding-top: 11px; padding-right: 11px; padding-bottom: 11px; padding-left: 11px; }
.p-12 { padding-top: 12px; padding-right: 12px; padding-bottom: 12px; padding-left: 12px; }
.p-13 { padding-top: 13px; padding-right: 13px; padding-bottom: 13px; padding-left: 13px; }
.p-14 { padding-top: 14px; padding-right: 14px; padding-bottom: 14px; padding-left: 14px; }
.p-15 { padding-top: 15px; padding-right: 15px; padding-bottom: 15px; padding-left: 15px; }
.p-16 { padding-top: 16px; padding-right: 16px; padding-bottom: 16px; padding-left: 16px; }
.p-17 { padding-top: 17px; padding-right: 17px; padding-bottom: 17px; padding-left: 17px; }
.p-18 { padding-top: 18px; padding-right: 18px; padding-bottom: 18px; padding-left: 18px; }
.p-19 { padding-top: 19px; padding-right: 19px; padding-bottom: 19px; padding-left: 19px; }
.p-20 { padding-top: 20px; padding-right: 20px; padding-bottom: 20px; padding-left: 20px; }

.px-0 { padding-left: 0px; padding-right: 0px; }
.px-1 { padding-left: 1px; padding-right: 1px; }
.px-2 { padding-left: 2px; padding-right: 2px; }
.px-3 { padding-left: 3px; padding-right: 3px; }
.px-4 { padding-left: 4px; padding-right: 4px; }
.px-5 { padding-left: 5px; padding-right: 5px; }
.px-6 { padding-left: 6px; padding-right: 6px; }
.px-7 { padding-left: 7px; padding-right: 7px; }
.px-8 { padding-left: 8px; padding-right: 8px; }
.px-9 { padding-left: 9px; padding-right: 9px; }
.px-10 { padding-left: 10px; padding-right: 10px; }
.px-11 { padding-left: 11px; padding-right: 11px; }
.px-12 { padding-left: 12px; padding-right: 12px; }
.px-13 { padding-left: 13px; padding-right: 13px; }
.px-14 { padding-left: 14px; padding-right: 14px; }
.px-15 { padding-left: 15px; padding-right: 15px; }
.px-16 { padding-left: 16px; padding-right: 16px; }
.px-17 { padding-left: 17px; padding-right: 17px; }
.px-18 { padding-left: 18px; padding-right: 18px; }
.px-19 { padding-left: 19px; padding-right: 19px; }
.px-20 { padding-left: 20px; padding-right: 20px; }
.px-21 { padding-left: 21px; padding-right: 21px; }
.px-22 { padding-left: 22px; padding-right: 22px; }
.px-23 { padding-left: 23px; padding-right: 23px; }
.px-24 { padding-left: 24px; padding-right: 24px; }
.px-25 { padding-left: 25px; padding-right: 25px; }
.px-26 { padding-left: 26px; padding-right: 26px; }
.px-27 { padding-left: 27px; padding-right: 27px; }
.px-28 { padding-left: 28px; padding-right: 28px; }
.px-29 { padding-left: 29px; padding-right: 29px; }
.px-30 { padding-left: 30px; padding-right: 30px; }
.px-31 { padding-left: 31px; padding-right: 31px; }
.px-32 { padding-left: 32px; padding-right: 32px; }
.px-33 { padding-left: 33px; padding-right: 33px; }
.px-34 { padding-left: 34px; padding-right: 34px; }
.px-35 { padding-left: 35px; padding-right: 35px; }
.px-36 { padding-left: 36px; padding-right: 36px; }
.px-37 { padding-left: 37px; padding-right: 37px; }
.px-38 { padding-left: 38px; padding-right: 38px; }
.px-39 { padding-left: 39px; padding-right: 39px; }
.px-40 { padding-left: 40px; padding-right: 40px; }


.py-0 { padding-top: 0px; padding-bottom: 0px; }
.py-1 { padding-top: 1px; padding-bottom: 1px; }
.py-2 { padding-top: 2px; padding-bottom: 2px; }
.py-3 { padding-top: 3px; padding-bottom: 3px; }
.py-4 { padding-top: 4px; padding-bottom: 4px; }
.py-5 { padding-top: 5px; padding-bottom: 5px; }
.py-6 { padding-top: 6px; padding-bottom: 6px; }
.py-7 { padding-top: 7px; padding-bottom: 7px; }
.py-8 { padding-top: 8px; padding-bottom: 8px; }
.py-9 { padding-top: 9px; padding-bottom: 9px; }
.py-10 { padding-top: 10px; padding-bottom: 10px; }
.py-11 { padding-top: 11px; padding-bottom: 11px; }
.py-12 { padding-top: 12px; padding-bottom: 12px; }
.py-13 { padding-top: 13px; padding-bottom: 13px; }
.py-14 { padding-top: 14px; padding-bottom: 14px; }
.py-15 { padding-top: 15px; padding-bottom: 15px; }
.py-16 { padding-top: 16px; padding-bottom: 16px; }
.py-17 { padding-top: 17px; padding-bottom: 17px; }
.py-18 { padding-top: 18px; padding-bottom: 18px; }
.py-19 { padding-top: 19px; padding-bottom: 19px; }
.py-20 { padding-top: 20px; padding-bottom: 20px; }
.py-21 { padding-top: 21px; padding-bottom: 21px; }
.py-22 { padding-top: 22px; padding-bottom: 22px; }
.py-23 { padding-top: 23px; padding-bottom: 23px; }
.py-24 { padding-top: 24px; padding-bottom: 24px; }
.py-25 { padding-top: 25px; padding-bottom: 25px; }
.py-26 { padding-top: 26px; padding-bottom: 26px; }
.py-27 { padding-top: 27px; padding-bottom: 27px; }
.py-28 { padding-top: 28px; padding-bottom: 28px; }
.py-29 { padding-top: 29px; padding-bottom: 29px; }
.py-30 { padding-top: 30px; padding-bottom: 30px; }
.py-31 { padding-top: 31px; padding-bottom: 31px; }
.py-32 { padding-top: 32px; padding-bottom: 32px; }
.py-33 { padding-top: 33px; padding-bottom: 33px; }
.py-34 { padding-top: 34px; padding-bottom: 34px; }
.py-35 { padding-top: 35px; padding-bottom: 35px; }
.py-36 { padding-top: 36px; padding-bottom: 36px; }
.py-37 { padding-top: 37px; padding-bottom: 37px; }
.py-38 { padding-top: 38px; padding-bottom: 38px; }
.py-39 { padding-top: 39px; padding-bottom: 39px; }
.py-40 { padding-top: 40px; padding-bottom: 40px; }

.pt-0 { padding-top: 0px; }
.pt-1 { padding-top: 1px; }
.pt-2 { padding-top: 2px; }
.pt-3 { padding-top: 3px; }
.pt-4 { padding-top: 4px; }
.pt-5 { padding-top: 5px; }
.pt-6 { padding-top: 6px; }
.pt-7 { padding-top: 7px; }
.pt-8 { padding-top: 8px; }
.pt-9 { padding-top: 9px; }
.pt-10 { padding-top: 10px; }
.pt-11 { padding-top: 11px; }
.pt-12 { padding-top: 12px; }
.pt-13 { padding-top: 13px; }
.pt-14 { padding-top: 14px; }
.pt-15 { padding-top: 15px; }
.pt-16 { padding-top: 16px; }
.pt-17 { padding-top: 17px; }
.pt-18 { padding-top: 18px; }
.pt-19 { padding-top: 19px; }
.pt-20 { padding-top: 20px; }
.pt-21 { padding-top: 21px; }
.pt-22 { padding-top: 22px; }
.pt-23 { padding-top: 23px; }
.pt-24 { padding-top: 24px; }
.pt-25 { padding-top: 25px; }
.pt-26 { padding-top: 26px; }
.pt-27 { padding-top: 27px; }
.pt-28 { padding-top: 28px; }
.pt-29 { padding-top: 29px; }
.pt-30 { padding-top: 30px; }
.pt-31 { padding-top: 31px; }
.pt-32 { padding-top: 32px; }
.pt-33 { padding-top: 33px; }
.pt-34 { padding-top: 34px; }
.pt-35 { padding-top: 35px; }
.pt-36 { padding-top: 36px; }
.pt-37 { padding-top: 37px; }
.pt-38 { padding-top: 38px; }
.pt-39 { padding-top: 39px; }
.pt-40 { padding-top: 40px; }
.pt-50 { padding-top: 50px; }


.pl-0 { padding-left: 0px; }
.pl-1 { padding-left: 1px; }
.pl-2 { padding-left: 2px; }
.pl-3 { padding-left: 3px; }
.pl-4 { padding-left: 4px; }
.pl-5 { padding-left: 5px; }
.pl-6 { padding-left: 6px; }
.pl-7 { padding-left: 7px; }
.pl-8 { padding-left: 8px; }
.pl-9 { padding-left: 9px; }
.pl-10 { padding-left: 10px; }
.pl-11 { padding-left: 11px; }
.pl-12 { padding-left: 12px; }
.pl-13 { padding-left: 13px; }
.pl-14 { padding-left: 14px; }
.pl-15 { padding-left: 15px; }
.pl-16 { padding-left: 16px; }
.pl-17 { padding-left: 17px; }
.pl-18 { padding-left: 18px; }
.pl-19 { padding-left: 19px; }
.pl-20 { padding-left: 20px; }
.pl-21 { padding-left: 21px; }
.pl-22 { padding-left: 22px; }
.pl-23 { padding-left: 23px; }
.pl-24 { padding-left: 24px; }
.pl-25 { padding-left: 25px; }
.pl-26 { padding-left: 26px; }
.pl-27 { padding-left: 27px; }
.pl-28 { padding-left: 28px; }
.pl-29 { padding-left: 29px; }
.pl-30 { padding-left: 30px; }
.pl-31 { padding-left: 31px; }
.pl-32 { padding-left: 32px; }
.pl-33 { padding-left: 33px; }
.pl-34 { padding-left: 34px; }
.pl-35 { padding-left: 35px; }
.pl-36 { padding-left: 36px; }
.pl-37 { padding-left: 37px; }
.pl-38 { padding-left: 38px; }
.pl-39 { padding-left: 39px; }
.pl-40 { padding-left: 40px; }

/* pr (padding-right) */
.pr-0 { padding-right: 0px; }
.pr-1 { padding-right: 1px; }
.pr-2 { padding-right: 2px; }
.pr-3 { padding-right: 3px; }
.pr-4 { padding-right: 4px; }
.pr-5 { padding-right: 5px; }
.pr-6 { padding-right: 6px; }
.pr-7 { padding-right: 7px; }
.pr-8 { padding-right: 8px; }
.pr-9 { padding-right: 9px; }
.pr-10 { padding-right: 10px; }
.pr-11 { padding-right: 11px; }
.pr-12 { padding-right: 12px; }
.pr-13 { padding-right: 13px; }
.pr-14 { padding-right: 14px; }
.pr-15 { padding-right: 15px; }
.pr-16 { padding-right: 16px; }
.pr-17 { padding-right: 17px; }
.pr-18 { padding-right: 18px; }
.pr-19 { padding-right: 19px; }
.pr-20 { padding-right: 20px; }
.pr-21 { padding-right: 21px; }
.pr-22 { padding-right: 22px; }
.pr-23 { padding-right: 23px; }
.pr-24 { padding-right: 24px; }
.pr-25 { padding-right: 25px; }
.pr-26 { padding-right: 26px; }
.pr-27 { padding-right: 27px; }
.pr-28 { padding-right: 28px; }
.pr-29 { padding-right: 29px; }
.pr-30 { padding-right: 30px; }
.pr-31 { padding-right: 31px; }
.pr-32 { padding-right: 32px; }
.pr-33 { padding-right: 33px; }
.pr-34 { padding-right: 34px; }
.pr-35 { padding-right: 35px; }
.pr-36 { padding-right: 36px; }
.pr-37 { padding-right: 37px; }
.pr-38 { padding-right: 38px; }
.pr-39 { padding-right: 39px; }
.pr-40 { padding-right: 40px; }


.pb-0 { padding-bottom: 0px; }
.pb-1 { padding-bottom: 1px; }
.pb-2 { padding-bottom: 2px; }
.pb-3 { padding-bottom: 3px; }
.pb-4 { padding-bottom: 4px; }
.pb-5 { padding-bottom: 5px; }
.pb-6 { padding-bottom: 6px; }
.pb-7 { padding-bottom: 7px; }
.pb-8 { padding-bottom: 8px; }
.pb-9 { padding-bottom: 9px; }
.pb-10 { padding-bottom: 10px; }
.pb-11 { padding-bottom: 11px; }
.pb-12 { padding-bottom: 12px; }
.pb-13 { padding-bottom: 13px; }
.pb-14 { padding-bottom: 14px; }
.pb-15 { padding-bottom: 15px; }
.pb-16 { padding-bottom: 16px; }
.pb-17 { padding-bottom: 17px; }
.pb-18 { padding-bottom: 18px; }
.pb-19 { padding-bottom: 19px; }
.pb-20 { padding-bottom: 20px; }
.pb-21 { padding-bottom: 21px; }
.pb-22 { padding-bottom: 22px; }
.pb-23 { padding-bottom: 23px; }
.pb-24 { padding-bottom: 24px; }
.pb-25 { padding-bottom: 25px; }
.pb-26 { padding-bottom: 26px; }
.pb-27 { padding-bottom: 27px; }
.pb-28 { padding-bottom: 28px; }
.pb-29 { padding-bottom: 29px; }
.pb-30 { padding-bottom: 30px; }
.pb-31 { padding-bottom: 31px; }
.pb-32 { padding-bottom: 32px; }
.pb-33 { padding-bottom: 33px; }
.pb-34 { padding-bottom: 34px; }
.pb-35 { padding-bottom: 35px; }
.pb-36 { padding-bottom: 36px; }
.pb-37 { padding-bottom: 37px; }
.pb-38 { padding-bottom: 38px; }
.pb-39 { padding-bottom: 39px; }
.pb-40 { padding-bottom: 40px; }


.pl-0 { padding-left: 0px; }
.pl-1 { padding-left: 1px; }
.pl-2 { padding-left: 2px; }
.pl-3 { padding-left: 3px; }
.pl-4 { padding-left: 4px; }
.pl-5 { padding-left: 5px; }
.pl-6 { padding-left: 6px; }
.pl-7 { padding-left: 7px; }
.pl-8 { padding-left: 8px; }
.pl-9 { padding-left: 9px; }
.pl-10 { padding-left: 10px; }
.pl-11 { padding-left: 11px; }
.pl-12 { padding-left: 12px; }
.pl-13 { padding-left: 13px; }
.pl-14 { padding-left: 14px; }
.pl-15 { padding-left: 15px; }
.pl-16 { padding-left: 16px; }
.pl-17 { padding-left: 17px; }
.pl-18 { padding-left: 18px; }
.pl-19 { padding-left: 19px; }
.pl-20 { padding-left: 20px; }
.pl-21 { padding-left: 21px; }
.pl-22 { padding-left: 22px; }
.pl-23 { padding-left: 23px; }
.pl-24 { padding-left: 24px; }
.pl-25 { padding-left: 25px; }
.pl-26 { padding-left: 26px; }
.pl-27 { padding-left: 27px; }
.pl-28 { padding-left: 28px; }
.pl-29 { padding-left: 29px; }
.pl-30 { padding-left: 30px; }
.pl-31 { padding-left: 31px; }
.pl-32 { padding-left: 32px; }
.pl-33 { padding-left: 33px; }
.pl-34 { padding-left: 34px; }
.pl-35 { padding-left: 35px; }
.pl-36 { padding-left: 36px; }
.pl-37 { padding-left: 37px; }
.pl-38 { padding-left: 38px; }
.pl-39 { padding-left: 39px; }
.pl-40 { padding-left: 40px; }


.mx-auto { margin-left: auto; margin-right: auto; }
.mx-0 { margin-left: 0px; margin-right: 0px; }
.mx-1 { margin-left: 1px; margin-right: 1px; }
.mx-2 { margin-left: 2px; margin-right: 2px; }
.mx-3 { margin-left: 3px; margin-right: 3px; }
.mx-4 { margin-left: 4px; margin-right: 4px; }
.mx-5 { margin-left: 5px; margin-right: 5px; }
.mx-6 { margin-left: 6px; margin-right: 6px; }
.mx-7 { margin-left: 7px; margin-right: 7px; }
.mx-8 { margin-left: 8px; margin-right: 8px; }
.mx-9 { margin-left: 9px; margin-right: 9px; }
.mx-10 { margin-left: 10px; margin-right: 10px; }
.mx-11 { margin-left: 11px; margin-right: 11px; }
.mx-12 { margin-left: 12px; margin-right: 12px; }
.mx-13 { margin-left: 13px; margin-right: 13px; }
.mx-14 { margin-left: 14px; margin-right: 14px; }
.mx-15 { margin-left: 15px; margin-right: 15px; }
.mx-16 { margin-left: 16px; margin-right: 16px; }
.mx-17 { margin-left: 17px; margin-right: 17px; }
.mx-18 { margin-left: 18px; margin-right: 18px; }
.mx-19 { margin-left: 19px; margin-right: 19px; }
.mx-20 { margin-left: 20px; margin-right: 20px; }
.mx-21 { margin-left: 21px; margin-right: 21px; }
.mx-22 { margin-left: 22px; margin-right: 22px; }
.mx-23 { margin-left: 23px; margin-right: 23px; }
.mx-24 { margin-left: 24px; margin-right: 24px; }
.mx-25 { margin-left: 25px; margin-right: 25px; }
.mx-26 { margin-left: 26px; margin-right: 26px; }
.mx-27 { margin-left: 27px; margin-right: 27px; }
.mx-28 { margin-left: 28px; margin-right: 28px; }
.mx-29 { margin-left: 29px; margin-right: 29px; }
.mx-30 { margin-left: 30px; margin-right: 30px; }
.mx-31 { margin-left: 31px; margin-right: 31px; }
.mx-32 { margin-left: 32px; margin-right: 32px; }
.mx-33 { margin-left: 33px; margin-right: 33px; }
.mx-34 { margin-left: 34px; margin-right: 34px; }
.mx-35 { margin-left: 35px; margin-right: 35px; }
.mx-36 { margin-left: 36px; margin-right: 36px; }
.mx-37 { margin-left: 37px; margin-right: 37px; }
.mx-38 { margin-left: 38px; margin-right: 38px; }
.mx-39 { margin-left: 39px; margin-right: 39px; }
.mx-40 { margin-left: 40px; margin-right: 40px; }

.my-0 { margin-top: 0px; margin-bottom: 0px; }
.my-1 { margin-top: 1px; margin-bottom: 1px; }
.my-2 { margin-top: 2px; margin-bottom: 2px; }
.my-3 { margin-top: 3px; margin-bottom: 3px; }
.my-4 { margin-top: 4px; margin-bottom: 4px; }
.my-5 { margin-top: 5px; margin-bottom: 5px; }
.my-6 { margin-top: 6px; margin-bottom: 6px; }
.my-7 { margin-top: 7px; margin-bottom: 7px; }
.my-8 { margin-top: 8px; margin-bottom: 8px; }
.my-9 { margin-top: 9px; margin-bottom: 9px; }
.my-10 { margin-top: 10px; margin-bottom: 10px; }
.my-11 { margin-top: 11px; margin-bottom: 11px; }
.my-12 { margin-top: 12px; margin-bottom: 12px; }
.my-13 { margin-top: 13px; margin-bottom: 13px; }
.my-14 { margin-top: 14px; margin-bottom: 14px; }
.my-15 { margin-top: 15px; margin-bottom: 15px; }
.my-16 { margin-top: 16px; margin-bottom: 16px; }
.my-17 { margin-top: 17px; margin-bottom: 17px; }
.my-18 { margin-top: 18px; margin-bottom: 18px; }
.my-19 { margin-top: 19px; margin-bottom: 19px; }
.my-20 { margin-top: 20px; margin-bottom: 20px; }
.my-21 { margin-top: 21px; margin-bottom: 21px; }
.my-22 { margin-top: 22px; margin-bottom: 22px; }
.my-23 { margin-top: 23px; margin-bottom: 23px; }
.my-24 { margin-top: 24px; margin-bottom: 24px; }
.my-25 { margin-top: 25px; margin-bottom: 25px; }
.my-26 { margin-top: 26px; margin-bottom: 26px; }
.my-27 { margin-top: 27px; margin-bottom: 27px; }
.my-28 { margin-top: 28px; margin-bottom: 28px; }
.my-29 { margin-top: 29px; margin-bottom: 29px; }
.my-30 { margin-top: 30px; margin-bottom: 30px; }
.my-31 { margin-top: 31px; margin-bottom: 31px; }
.my-32 { margin-top: 32px; margin-bottom: 32px; }
.my-33 { margin-top: 33px; margin-bottom: 33px; }
.my-34 { margin-top: 34px; margin-bottom: 34px; }
.my-35 { margin-top: 35px; margin-bottom: 35px; }
.my-36 { margin-top: 36px; margin-bottom: 36px; }
.my-37 { margin-top: 37px; margin-bottom: 37px; }
.my-38 { margin-top: 38px; margin-bottom: 38px; }
.my-39 { margin-top: 39px; margin-bottom: 39px; }
.my-40 { margin-top: 40px; margin-bottom: 40px; }

.mt-0 { margin-top: 0px; }
.mt-1 { margin-top: 1px; }
.mt-2 { margin-top: 2px; }
.mt-3 { margin-top: 3px; }
.mt-4 { margin-top: 4px; }
.mt-5 { margin-top: 5px; }
.mt-6 { margin-top: 6px; }
.mt-7 { margin-top: 7px; }
.mt-8 { margin-top: 8px; }
.mt-9 { margin-top: 9px; }
.mt-10 { margin-top: 10px; }
.mt-11 { margin-top: 11px; }
.mt-12 { margin-top: 12px; }
.mt-13 { margin-top: 13px; }
.mt-14 { margin-top: 14px; }
.mt-15 { margin-top: 15px; }
.mt-16 { margin-top: 16px; }
.mt-17 { margin-top: 17px; }
.mt-18 { margin-top: 18px; }
.mt-19 { margin-top: 19px; }
.mt-20 { margin-top: 20px; }
.mt-21 { margin-top: 21px; }
.mt-22 { margin-top: 22px; }
.mt-23 { margin-top: 23px; }
.mt-24 { margin-top: 24px; }
.mt-25 { margin-top: 25px; }
.mt-26 { margin-top: 26px; }
.mt-27 { margin-top: 27px; }
.mt-28 { margin-top: 28px; }
.mt-29 { margin-top: 29px; }
.mt-30 { margin-top: 30px; }
.mt-31 { margin-top: 31px; }
.mt-32 { margin-top: 32px; }
.mt-33 { margin-top: 33px; }
.mt-34 { margin-top: 34px; }
.mt-35 { margin-top: 35px; }
.mt-36 { margin-top: 36px; }
.mt-37 { margin-top: 37px; }
.mt-38 { margin-top: 38px; }
.mt-39 { margin-top: 39px; }
.mt-40 { margin-top: 40px; }
.mt-52 { margin-top: 52px; }

.mr-0 { margin-right: 0px; }
.mr-1 { margin-right: 1px; }
.mr-2 { margin-right: 2px; }
.mr-3 { margin-right: 3px; }
.mr-4 { margin-right: 4px; }
.mr-5 { margin-right: 5px; }
.mr-6 { margin-right: 6px; }
.mr-7 { margin-right: 7px; }
.mr-8 { margin-right: 8px; }
.mr-9 { margin-right: 9px; }
.mr-10 { margin-right: 10px; }
.mr-11 { margin-right: 11px; }
.mr-12 { margin-right: 12px; }
.mr-13 { margin-right: 13px; }
.mr-14 { margin-right: 14px; }
.mr-15 { margin-right: 15px; }
.mr-16 { margin-right: 16px; }
.mr-17 { margin-right: 17px; }
.mr-18 { margin-right: 18px; }
.mr-19 { margin-right: 19px; }
.mr-20 { margin-right: 20px; }
.mr-21 { margin-right: 21px; }
.mr-22 { margin-right: 22px; }
.mr-23 { margin-right: 23px; }
.mr-24 { margin-right: 24px; }
.mr-25 { margin-right: 25px; }
.mr-26 { margin-right: 26px; }
.mr-27 { margin-right: 27px; }
.mr-28 { margin-right: 28px; }
.mr-29 { margin-right: 29px; }
.mr-30 { margin-right: 30px; }
.mr-31 { margin-right: 31px; }
.mr-32 { margin-right: 32px; }
.mr-33 { margin-right: 33px; }
.mr-34 { margin-right: 34px; }
.mr-35 { margin-right: 35px; }
.mr-36 { margin-right: 36px; }
.mr-37 { margin-right: 37px; }
.mr-38 { margin-right: 38px; }
.mr-39 { margin-right: 39px; }
.mr-40 { margin-right: 40px; }

.mb-0 { margin-bottom: 0px; }
.mb-1 { margin-bottom: 1px; }
.mb-2 { margin-bottom: 2px; }
.mb-3 { margin-bottom: 3px; }
.mb-4 { margin-bottom: 4px; }
.mb-5 { margin-bottom: 5px; }
.mb-6 { margin-bottom: 6px; }
.mb-7 { margin-bottom: 7px; }
.mb-8 { margin-bottom: 8px; }
.mb-9 { margin-bottom: 9px; }
.mb-10 { margin-bottom: 10px; }
.mb-11 { margin-bottom: 11px; }
.mb-12 { margin-bottom: 12px; }
.mb-13 { margin-bottom: 13px; }
.mb-14 { margin-bottom: 14px; }
.mb-15 { margin-bottom: 15px; }
.mb-16 { margin-bottom: 16px; }
.mb-17 { margin-bottom: 17px; }
.mb-18 { margin-bottom: 18px; }
.mb-19 { margin-bottom: 19px; }
.mb-20 { margin-bottom: 20px; }
.mb-21 { margin-bottom: 21px; }
.mb-22 { margin-bottom: 22px; }
.mb-23 { margin-bottom: 23px; }
.mb-24 { margin-bottom: 24px; }
.mb-25 { margin-bottom: 25px; }
.mb-26 { margin-bottom: 26px; }
.mb-27 { margin-bottom: 27px; }
.mb-28 { margin-bottom: 28px; }
.mb-29 { margin-bottom: 29px; }
.mb-30 { margin-bottom: 30px; }
.mb-31 { margin-bottom: 31px; }
.mb-32 { margin-bottom: 32px; }
.mb-33 { margin-bottom: 33px; }
.mb-34 { margin-bottom: 34px; }
.mb-35 { margin-bottom: 35px; }
.mb-36 { margin-bottom: 36px; }
.mb-37 { margin-bottom: 37px; }
.mb-38 { margin-bottom: 38px; }
.mb-39 { margin-bottom: 39px; }
.mb-40 { margin-bottom: 40px; }

.ml-0 { margin-left: 0px; }
.ml-1 { margin-left: 1px; }
.ml-2 { margin-left: 2px; }
.ml-3 { margin-left: 3px; }
.ml-4 { margin-left: 4px; }
.ml-5 { margin-left: 5px; }
.ml-6 { margin-left: 6px; }
.ml-7 { margin-left: 7px; }
.ml-8 { margin-left: 8px; }
.ml-9 { margin-left: 9px; }
.ml-10 { margin-left: 10px; }
.ml-11 { margin-left: 11px; }
.ml-12 { margin-left: 12px; }
.ml-13 { margin-left: 13px; }
.ml-14 { margin-left: 14px; }
.ml-15 { margin-left: 15px; }
.ml-16 { margin-left: 16px; }
.ml-17 { margin-left: 17px; }
.ml-18 { margin-left: 18px; }
.ml-19 { margin-left: 19px; }
.ml-20 { margin-left: 20px; }
.ml-21 { margin-left: 21px; }
.ml-22 { margin-left: 22px; }
.ml-23 { margin-left: 23px; }
.ml-24 { margin-left: 24px; }
.ml-25 { margin-left: 25px; }
.ml-26 { margin-left: 26px; }
.ml-27 { margin-left: 27px; }
.ml-28 { margin-left: 28px; }
.ml-29 { margin-left: 29px; }
.ml-30 { margin-left: 30px; }
.ml-31 { margin-left: 31px; }
.ml-32 { margin-left: 32px; }
.ml-33 { margin-left: 33px; }
.ml-34 { margin-left: 34px; }
.ml-35 { margin-left: 35px; }
.ml-36 { margin-left: 36px; }
.ml-37 { margin-left: 37px; }
.ml-38 { margin-left: 38px; }
.ml-39 { margin-left: 39px; }
.ml-40 { margin-left: 40px; }


/* Typography */

.text-0 { font-size: 0; }
.text-8 { font-size: 8px; }
.text-9 { font-size: 9px; }
.text-10 { font-size: 10px; }
.text-11 { font-size: 11px; }
.text-12 { font-size: 12px; }
.text-13 { font-size: 13px; }
.text-14 { font-size: 14px; }
.text-15 { font-size: 15px; }
.text-16 { font-size: 16px; }
.text-17 { font-size: 17px; }
.text-18 { font-size: 18px; }
.text-19 { font-size: 19px; }
.text-20 { font-size: 20px; }
.text-21 { font-size: 21px; }
.text-22 { font-size: 22px; }
.text-23 { font-size: 23px; }
.text-24 { font-size: 24px; }
.text-25 { font-size: 25px; }
.text-26 { font-size: 26px; }
.text-27 { font-size: 27px; }
.text-28 { font-size: 28px; }
.text-29 { font-size: 29px; }
.text-30 { font-size: 30px; }
.text-32 { font-size: 32px; }
.text-34 { font-size: 34px; }
.text-36 { font-size: 36px; }
.text-38 { font-size: 38px; }
.text-40 { font-size: 40px; }
.text-42 { font-size: 42px; }
.text-44 { font-size: 44px; }
.text-46 { font-size: 46px; }
.text-48 { font-size: 48px; }
.text-50 { font-size: 50px; }

.italic { font-style: italic; }
.not-italic { font-style: normal; }

.font-thin { font-weight: 100; }
.font-extralight { font-weight: 200; }
.font-light { font-weight: 300; }
.font-normal { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }
.font-extrabold { font-weight: 800; }
.font-black { font-weight: 900; }

.tracking-1 { letter-spacing: 1px; }
.tracking-2 { letter-spacing: 2px; }
.tracking-3 { letter-spacing: 3px; }
.tracking-4 { letter-spacing: 4px; }
.tracking-5 { letter-spacing: 5px; }
.tracking-6 { letter-spacing: 6px; }
.tracking-7 { letter-spacing: 7px; }
.tracking-8 { letter-spacing: 8px; }
.tracking-9 { letter-spacing: 9px; }
.tracking-10 { letter-spacing: 10px; }


.line-clamp-1 { text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1; line-clamp: 1; overflow: hidden; }
.line-clamp-2 { text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; line-clamp: 1; overflow: hidden; }
.line-clamp-3 { text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-clamp: 1; overflow: hidden; }


.leading-10 { line-height: 10px; }
.leading-11 { line-height: 11px; }
.leading-12 { line-height: 12px; }
.leading-13 { line-height: 13px; }
.leading-14 { line-height: 14px; }
.leading-15 { line-height: 15px; }
.leading-16 { line-height: 16px; }
.leading-17 { line-height: 17px; }
.leading-18 { line-height: 18px; }
.leading-19 { line-height: 19px; }
.leading-20 { line-height: 20px; }
.leading-21 { line-height: 21px; }
.leading-22 { line-height: 22px; }
.leading-23 { line-height: 23px; }
.leading-24 { line-height: 24px; }
.leading-25 { line-height: 25px; }
.leading-26 { line-height: 26px; }
.leading-27 { line-height: 27px; }
.leading-28 { line-height: 28px; }
.leading-29 { line-height: 29px; }
.leading-30 { line-height: 30px; }
.leading-31 { line-height: 31px; }
.leading-32 { line-height: 32px; }
.leading-33 { line-height: 33px; }
.leading-34 { line-height: 34px; }
.leading-35 { line-height: 35px; }
.leading-36 { line-height: 36px; }
.leading-37 { line-height: 37px; }
.leading-38 { line-height: 38px; }
.leading-39 { line-height: 39px; }
.leading-40 { line-height: 40px; }
.leading-41 { line-height: 41px; }
.leading-42 { line-height: 42px; }
.leading-43 { line-height: 43px; }
.leading-44 { line-height: 44px; }
.leading-45 { line-height: 45px; }
.leading-46 { line-height: 46px; }
.leading-47 { line-height: 47px; }
.leading-48 { line-height: 48px; }
.leading-49 { line-height: 49px; }
.leading-50 { line-height: 50px; }
.leading-51 { line-height: 51px; }
.leading-52 { line-height: 52px; }
.leading-53 { line-height: 53px; }
.leading-54 { line-height: 54px; }
.leading-55 { line-height: 55px; }
.leading-56 { line-height: 56px; }
.leading-57 { line-height: 57px; }
.leading-58 { line-height: 58px; }
.leading-59 { line-height: 59px; }
.leading-60 { line-height: 60px; }

.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-justify { text-align: justify; }
.text-start { text-align: start; }
.text-end { text-align: end; }

.uppercase { text-transform: uppercase; }
.lowercase { text-transform: lowercase; }
.capitalize { text-transform: capitalize; }


.whitespace-normal { white-space: normal; }
.whitespace-nowrap { white-space: nowrap; }
.whitespace-pre { white-space: pre; }
.whitespace-pre-line { white-space: pre-line; }
.whitespace-pre-wrap { white-space: pre-wrap; }
.whitespace-break-spaces { white-space: break-spaces; }

.break-normal { word-break: normal; }
.break-all { word-break: break-all; }
.break-keep { word-break: keep-all; }


.underline { text-decoration-line: underline; }
.overline { text-decoration-line: overline; }
.line-through { text-decoration-line: line-through; }
.no-underline { text-decoration-line: none; }



/* TODO:继续补充 */

/**********************
 ** Borders & Radius
 **********************/
.border { border: 1px solid #ECECEC;}
.border-top { border-top: 1px solid #ECECEC;}
.border-right { border-right: 1px solid #ECECEC;}
.border-bottom { border-bottom: 1px solid #ECECEC;}
.border-left { border-left: 1px solid #ECECEC;}

.border-0 { border: none;}
.border-top-0 { border-top: none;}
.border-right-0 { border-right: none;}
.border-bottom-0 { border-bottom: none;}
.border-left-0 { border-left: none;}

.border-dashed { border-style: dashed; }

.border-transparent { border-color: transparent; }
.border-light { border-color: #FFFFFF; }
.border-dark  { border-color: #000000; }

.border-FFCA2A { border-color: #FFCA2A; }
.border-F1F1F1 { border-color: #F1F1F1; }
.border-F2F2F2 { border-color: #F2F2F2; }
.border-DBDBDB { border-color: #DBDBDB; } 
.border-E5E5E5 { border-color: #E5E5E5; }
.border-FFC689 { border-color: #FFC689; }


/* Radius */
.rounded-xs   { border-radius: 2px;}
.rounded-sm   { border-radius: 4px;}
.rounded-md   { border-radius: 6px;}
.rounded-lg   { border-radius: 8px;}
.rounded-xl   { border-radius: 12px;}
.rounded-2xl  { border-radius: 16px;}
.rounded-3xl  { border-radius: 24px;}
.rounded-4xl  { border-radius: 32px;}
.rounded-full { border-radius: calc(infinity * 1px);}




/**********************
 ** iconSize
 **********************/
.icon-10x10 { width: 10px; height: 10px; }
.icon-11x11 { width: 11px; height: 11px; }
.icon-12x12 { width: 12px; height: 12px; }
.icon-13x13 { width: 13px; height: 13px; }
.icon-14x14 { width: 14px; height: 14px; }
.icon-15x15 { width: 15px; height: 15px; }
.icon-16x16 { width: 16px; height: 16px; }
.icon-17x17 { width: 17px; height: 17px; }
.icon-18x18 { width: 18px; height: 18px; }
.icon-19x19 { width: 19px; height: 19px; }
.icon-20x20 { width: 20px; height: 20px; }
.icon-21x21 { width: 21px; height: 21px; }
.icon-22x22 { width: 22px; height: 22px; }
.icon-23x23 { width: 23px; height: 23px; }
.icon-24x24 { width: 24px; height: 24px; }
.icon-25x25 { width: 25px; height: 25px; }
.icon-26x26 { width: 26px; height: 26px; }
.icon-27x27 { width: 27px; height: 27px; }
.icon-28x28 { width: 28px; height: 28px; }
.icon-29x29 { width: 29px; height: 29px; }
.icon-30x30 { width: 30px; height: 30px; }
.icon-31x31 { width: 31px; height: 31px; }
.icon-32x32 { width: 32px; height: 32px; }
.icon-33x33 { width: 33px; height: 33px; }
.icon-34x34 { width: 34px; height: 34px; }
.icon-35x35 { width: 35px; height: 35px; }
.icon-36x36 { width: 36px; height: 36px; }
.icon-37x37 { width: 37px; height: 37px; }
.icon-38x38 { width: 38px; height: 38px; }
.icon-39x39 { width: 39px; height: 39px; }
.icon-40x40 { width: 40px; height: 40px; }
.icon-41x41 { width: 41px; height: 41px; }
.icon-42x42 { width: 42px; height: 42px; }
.icon-43x43 { width: 43px; height: 43px; }
.icon-44x44 { width: 44px; height: 44px; }
.icon-45x45 { width: 45px; height: 45px; }
.icon-46x46 { width: 46px; height: 46px; }
.icon-47x47 { width: 47px; height: 47px; }
.icon-48x48 { width: 48px; height: 48px; }
.icon-49x49 { width: 49px; height: 49px; }
.icon-50x50 { width: 50px; height: 50px; }
.icon-52x52 { width: 52px; height: 52px; }
.icon-56x56 { width: 56px; height: 56px; }
.icon-57x57 { width: 57px; height: 57px; }
.icon-58x58 { width: 58px; height: 58px; }
.icon-60x60 { width: 60px; height: 60px; }
.icon-64x64 { width: 64px; height: 64px; }
.icon-68x68 { width: 68px; height: 68px; }
.icon-70x70 { width: 70px; height: 70px; }
.icon-90x90 { width: 90px; height: 90px; }
.object-fit-cover {object-fit: cover}


/* Effects */
.opacity-0 { opacity: 0; }
.opacity-10 { opacity: 0.1; }
.opacity-20 { opacity: 0.2; }
.opacity-30 { opacity: 0.3; }
.opacity-40 { opacity: 0.4; }
.opacity-50 { opacity: 0.5; }
.opacity-60 { opacity: 0.6; }
.opacity-70 { opacity: 0.7; }
.opacity-80 { opacity: 0.8; }
.opacity-90 { opacity: 0.9; }
.opacity-100 { opacity: 1; }


.cursor-auto { cursor: auto; }
.cursor-default { cursor: default; }
.cursor-pointer { cursor: pointer; }
.cursor-wait { cursor: wait; }
.cursor-text { cursor: text; }
.cursor-move { cursor: move; }
.cursor-help { cursor: help; }
.cursor-not-allowed { cursor: not-allowed; }
.cursor-none { cursor: none; }
.cursor-context-menu { cursor: context-menu; }
.cursor-progress { cursor: progress; }
.cursor-cell { cursor: cell; }
.cursor-crosshair { cursor: crosshair; }
.cursor-vertical-text { cursor: vertical-text; }
.cursor-alias { cursor: alias; }
.cursor-copy { cursor: copy; }
.cursor-no-drop { cursor: no-drop; }
.cursor-grab { cursor: grab; }
.cursor-grabbing { cursor: grabbing; }
.cursor-all-scroll { cursor: all-scroll; }
.cursor-col-resize { cursor: col-resize; }
.cursor-row-resize { cursor: row-resize; }
.cursor-n-resize { cursor: n-resize; }
.cursor-e-resize { cursor: e-resize; }
.cursor-s-resize { cursor: s-resize; }
.cursor-w-resize { cursor: w-resize; }
.cursor-ne-resize { cursor: ne-resize; }
.cursor-nw-resize { cursor: nw-resize; }
.cursor-se-resize { cursor: se-resize; }
.cursor-sw-resize { cursor: sw-resize; }
.cursor-ew-resize { cursor: ew-resize; }
.cursor-ns-resize { cursor: ns-resize; }
.cursor-nesw-resize { cursor: nesw-resize; }
.cursor-nwse-resize { cursor: nwse-resize; }
.cursor-zoom-in { cursor: zoom-in; }
.cursor-zoom-out { cursor: zoom-out; }


/* 气泡框 */
.bubble {
	display: inline-block;
	height: 14px;
	background-color: #FF7E26;
	border-radius: 2px;
	padding: 0 4px;
	color: #FFFFFF;
	
	white-space: nowrap;
	font-size: 9px;
	text-align: center;
	line-height: 14px;
	position: relative;
}
.bubble::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: #FF7E26 transparent transparent transparent;
	border-width: 5px 3px 0 3px;
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
}


/* RichText */
.rich-html * { max-width: 100% !important; }
.rich-html img { height: auto !important; }


/**********************
 ** Space
 **********************/
.space-43 { height: 43px; }
.space-50 { height: 50px; }
.space-88 { height: 88px; }
.space-89 { height: 89px; }
.space-99 { height: 99px; }